<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .box {
        width: 200px;
        height: 200px;
        border: 1px solid red;
      }
    </style>
  </head>
  <body>
    <div id="app">
      <div class="box" @contextmenu.prevent="fun1" @keydown="fun2"></div>
      <!-- div的键盘事件不起作用  -->

      <!-- 只有document还有input可以触发键盘事件 -->

      <input type="text" @keydown.13="fun2" />
      <input type="text" @keydown.enter="fun2" />
      <input type="text" @keydown.up="fun2" />
      <input type="text" @keydown.down="fun2" />
      <input type="text" @keydown.left="fun2" />
      <input type="text" @keydown.right="fun2" />
      <!-- 键盘事件的修饰符 是键码值 也有一些常用的按键有别称 -->
    </div>
    <script src="vue-2.4.0.js"></script>
    <script>
      var vm = new Vue({
        el: "#app",
        data: {},
        methods: {
          fun1() {
            console.log("111");
          },
          fun2() {
            console.log(222);
          },
        },
      });
      //   事件修饰符：
      //   普通事件修饰符 （阻止默认事件 .prevent）（ 阻止冒泡 .stop ）（ 触发捕获
      //   .capture）
      //   键盘事件修饰符
      //   键盘事件的修饰符 是键码值 也有一些常用的按键有别称
    </script>
  </body>
</html>
